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IMPROVED DATA TRANSMISSION OPTIMIZER 



15 This invention relates to improvements in a system 

for optimizing data transmissions such as that disclosed 
in the '137 patent. 

Buffer Difference Mapping 

20 

Referring to Figures 1 and 2, the r 137 patent and 
the f 150 application disclose mapping-type optimizing 
systems for optimizing data exchanges between a host unit 
25 (e.g., a data base application program running on a 
25 programmable computer) and a peripheral device 15 that 

has an addressable buffer (e.g., a terminal device). The 
addressable buffer may be a screen buffer 16 and /or one 
or more programmable symbol buffers 17. 

30 Generally speaking, if the host unit 25 attempts to 

send any signal to the peripheral device 15 (e.g., a 
signal that would cause an erasure and a subsequent 
rewriting of the device's buffer), the optimizing system: 

35 (1) intercepts or blocks the attempt; 

(2) compares (i) a present-state map of the existing 
information contents of the buffer with (ii) an intended- 
state map of those information contents as expected to 
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exist after receipt of the signal by the peripheral 
device 15; 

(3) constructs a new signal that, instead of erasing 
and rewriting the buffer, "surgically" changes only those 
portions of the buffer that need changing; and 

(4) sends the new signal to the peripheral device 15 
in place of the original signal from the host unit 25. 



As shown in Figure 2, the map comparison step 
generally consists of performing an exclusive-or (XOR) 
process, using the present-state map and the intended- 
state map as operands, to generate a difference map. In 
15 the difference map, null characters signify locations 
where the present-state map and the intended-state map 
are identical; non-null characters signify locations 
where they differ. From this information, the new signal 
is constructed. 



Programmed Symbol Buffers 



Many types of peripheral device 15 include one or 
more programmable symbol buffers 17, each of which has a 

25 specified number of memory blocks or "slots" for storage 
of bit-mapped symbol images. Typically, for example, a 
peripheral device 15 supporting the IBM 3270 protocol may 
.include several symbol buffers; a host unit 25 can 
program any given slot with a specific bit-mapped symbol 

3 0 image . 

The host unit 25 can then cause graphic shapes to be 
displayed on the peripheral device 15 by ordering 
particular symbol images (identified by "code point" 
35 designators) to be displayed at specific points on the 
screen of the peripheral device 15. 
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Figure 3 shows an example of two slots in a 
programmed symbol buffer. A slot 4 6 contains a bit- 
mapped image of a straight vertical line; a slot 49 
5 contains a similar image of an upward caret. A vertical 
arrow can be displayed on the screen of the peripheral 
device 15 by ordering the slot 4 6 to be displayed at two 
^ places on the screen, one above the other, with the slot 
49 being displayed just above that. 

10 

Multi-color Symbol Buffers 

As shown in Figure 4, some peripheral devices 15 
have the capability to display symbols in color through 

15 the use of separate buffer planes for separate colors. 
For example, a peripheral device 15 may have a "red" 
plane, a "blue" one, and a "green" one. Various colors 
(see Appendix 10) can be displayed by setting selected 
bits in the appropriate planes; for example, a portion of 

20 a symbol can be displayed on the screen in white by 

setting the corresponding bits in all three color planes 
of the symbol buffer. 

In accordance with the present invention, an 
25 optimizer performs additional optimization in conjunction 
with the optimization system of the '137 patent. 

A QUERY SUPPRESSION routine is performed to suppress 
redundant device-capability queries sent by a host unit 

30 applica- tions program 25 to a peripheral device 15. 

Whenever such a query command is initiated by the host 
unit applica tions program 25, the optimizer checks its 
own saved infor mat ion to determine whether the 
information requested by the host unit has already been 

35 obtained. If so, the QUERY SUPPRESSION routine writes a 
minimal substitute query command. When the reply comes 
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back from the peripheral device, the optimizer "fills in 
the blanks," using its previously stored information, to 
provide the reply signal expected by the host unit. 

. 5 A READ BUFFER SUPPRESSION routine is performed to 

suppress commands reguesting that the peripheral device 
15 transmit the entire contents of its screen buffer 16 
inbound. Whenever such a command is initiated by the 
host unit applications program 25, the optimizer checks 
10 its own saved information to determine whether the 

information requested by the host unit has already been 
obtained. If so, the READ BUFFER SUPPRESSION routine 
writes a minimal substitute command. When the reply 
comes back from the peripheral device, the optimizer 
15 "fills .in the blanks," using its previously stored 

information, to provide the reply signal expected by the 
host unit. 

The optimizer performs a multi-pass scan to optimize 
20 multiple-plane symbol buffers. A total of seven scanning 
passes of the difference map planes is made: A triple- 
plane scan in search of white characters; three dual-plan 
scans in search of turquoise, yellow, and pink 
characters, respectively; and three single-pass scans in 
search of red, blue, and green characters, respectively. 
This minimizes the length of the output signal required 
to effect the changes to the multiple planes. 

A DARK FIELD ELIMINATION routine is performed: 
30 protected "dark" fields are overwritten with nulls in the 
present-state and intended-state maps, so that the 
4 contents of the dark fields are not included in the 

{) outgoing signal. 

35 A DEVICE-SPECIFIC ATTRIBUTE ELIMINATION routine is 

performed: if the peripheral device 15 is not capable of 
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displaying information in different attributes (e.g., 
some display devices are not capable of displaying data 
in a blinking manner) , all such attributes in the 
present-state and intended- state maps are overwritten 
5 with nulls, so that the attributes are not included in 
the outgoing signal. 

An MDT-reset voting routine is performed to 
determine whether selective setting of modified data tags 
10 (MDTs) can be done more effectively by (a) clearing all 
MDTs and individually setting desired MDTs, or (b) 
individually clearing desired MDTs. The approach 
resulting in the shorter signal is utilized. 

15 For each triplet of non-null, null, and non-null 

character sequences in the map being scanned, the 
optimizer tests whether a shorter signal would result 
from (a) writing two separate subsignals, one for each of 
the non-null character sequences, or (b) writing a single 

20 signal encompassing all three sequences as a single 

concatenated sequence. The approach resulting in the 
shorter signal is utilized. 

A present-state list of values of programmed symbols 
25 already downloaded to a peripheral device 15 is sorted, 
and a similar intended-state list of programmed symbols 
intended to be downloaded is likewise sorted. A search 
is performed to detect any commonalities that might exist 
between the present-state and intended-state programmed- 
30 symbol values, even under differing programmed-symbol 
designators. When such a commonality is detected, the 
intended- state designator is altered to be equal to the 
present-state designator; thus, that particular 
programmed symbol value need not be redownloaded. 

35 
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Figure 1 is a simplified block diagram of a typical 
host unit applications program as used in a telecommuni- 
cations system, having an optimizer in accordance with 
the present invention interposed between the applications 
5 program and a signal routing unit. 

Figure 2 is a block diagram of the exclusive-or 
(XOR) process used in the '137 patent to generate a 
difference map signifying changes in a buffer of a 
10 peripheral device. 

Figure 3 is a sketch of two programmed symbol buffer 
slots. Figure 4 is a sketch of an arrangement of three 
color-related buffer planes in a programmed symbol 
15 buffer. 

Figure 5 is. a diagrammatic overview of certain 
processes in accordance with the invention. 



20 



Figure 6 is a simplified representation of the 
contents of a screen buffer with a "dark field" included. 



Figure 7 is a simplified representation of a scan : 
map as used in the TEST SIGNAL routine (Appendixes 25- : 
25 27) . 

Throughout the following description, like numerals 
refer to like parts in all drawings. 

30 Referring to Figure 1, a telecommunications system 

is shown in which incoming and outgoing signals are 
exchanged between a peripheral device 15 and a host 
computer 20. (An incoming signal is defined here as a| 
signal transmitted from the peripheral device 15 to the 

35 host computer 20, and vice versa.) The peripheral device 
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15 includes a screen buffer 16 and one or more 
programmable symbol buffers 17 • 



The host computer 2 0 typically executes multiple 
5 computer programs substantially concurrently (e.g., in a 
multi programming environment such as provided by the IBM 
MVS system) . As shown in Figure 1, the host computer 20 
executes host unit application programs 25 and a signal- 
routing unit program 3 0 which handles communications 
10 between the host computer 20 and the peripheral device 
15. 



An optimizer 35 monitors communications between the 
host units 25 and the peripheral device 15 by 
15 intercepting incoming and outgoing signals. As shown in 
Figure 1, the optimizer 35 is interposed between the host 
units 25 and the signal-routing unit 30. 



Pseudocode Appendixes 

20 

The optimizer 35 may be implemented by programming 
• the host computer 20 to perform the functions described 
herein as shown in Figure 1. For purposes of illustra- 
tion, the discussion below refers periodically to 
25 programming of a computer operating in conjunction with 
the well-known IBM 3270 communications protocol and MVS 
operating system. 

| Alternatively, of course, the optimizer 35 could be 
30 implemented in, or as, a machine separate from the host 
computer 20, interposed between the host computer 20 and 
the peripheral device 15. 



Appendixes 1 through 3 0 set forth a generalized 
35 5)seudo code outline, in a "structured English" format, of 
an exemplar design for a computer program in accordance 
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with the invention. The pseudocode is intended as a 
general description and is not meant to be limiting. For 
example, it uses the term "data structure" somewhat 
loosely, to describe generically a simple variable in 
memory, a complex data structure, a disk file, or other 
means for storing data. 



For convenience of illustration, the pseudocode is 
broken down into a number of routines. However, those 
10 skilled in the art will appreciate that some of the 

routines may be combined, and others may be broken down 
still further. 



The actual optimum organization and structure of an 
15 computer program in accordance with the invention will 
depend greatly on the characteristics of the system on 
which the invention is implemented. Certain functions 
described in the pseudocode may not be available on a 
given machine and must be simulated; or, a group of 
20 functions described here may be able to be collapsed into 
fewer functions on another machine. 

The pseudocode is only an outline and does not nec- 
es sarily set forth a complete program listing. For 
25 example, testing for boundary conditions is sometimes 

described ex plicitly in the pseudocode and sometimes is 
referred to only implicitly. By and large, the 
pseudocode does not set forth error trapping/ handling or 
similar functions. 



30 



35 



It will be recognized by those of ordinary skill 
that, given the benefit of this disclosure, the 
implementation of an optimizer 35 on any given model of 
computer running any given operating system, to take 
advantage of the features of the computer and operating 
system, is a matter of conventional programming by those 
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familiar with the particular computer and operating 
system. 

General Approach 

5 

The general design approach of the optimizer 3 5 for 
outgoing signals may be described as follows: an 
outgoing signal generated by a host unit applications 
program 25 is parsed into what may be termed component 

I(J parts. Commands in the outgoing signal that would affect 
the screen buffer 16 are processed, and substitute 
component -part commands are generated. Likewise, 
commands affecting any symbol buffers 17 are processed, 
and substitute component-parts for those commands are 

15 generated. Finally, a substitute signal is constructed 
from the substitute component parts. 

Query Suppression 

20 Some telecommunications protocols (e.g., the IBM 

3270 protocol) permit a host unit 25 to use a query 
command to interrogate the peripheral device 15 as to the 
peripheral device's characteristics (e.g., screen colors 
supported, symbol buffer availability, etc.)* Upon 

25 receipt of such a query, the peripheral device 15 
responds with a signal specifying the requested 
information. 

Some host units 25 may be programmed to send such a 
30 query with every outgoing signal. This can result in 
needless repetitive transmission of the same requested 
information. 

To reduce such repetitive transmissions, the 
35 optimizer 3 5 may include a QUERY SUPPRESSION routine, 
e.g., as is set forth in Appendix 4. 
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As shown in Appendix 4, when a host unit 25 
generates a query signal, the QUERY SUPPRESSION routine 
checks whether the requested information has already been 
received. If not, the optimizer 35 passes the query 
signal on unchanged. When the response to the query 
signal is received from the peripheral device 15, the 
optimizer 35 saves the contents of the response. (See 
Appendix 30.) 



Upon subsequent query signals to the same peripheral 
device 15, the optimizer 35 in essence converts the query 
signal to the minimum query signal that can be generated 
(see Appendix 4) . In an IBM 3270-type system, for 
15 example, a query signal may be a READ PARTITION QUERY 
command. If the requested information about the 
peripheral device 15 has already been received r the QUERY 
SUPPRESSION routine converts this command to a READ 
PARTITION QUERY LIST NULL command. Upon receipt of the 
peripheral device 15' s response to the query signal, the 
♦optimizer 35 converts the response to conform to the 
query signal initiated by the host unit 25. 



Read Buffer Suppression 



Some telecommunications protocols allow a command to 
be transmitted to a peripheral device 15 that causes the 
peripheral device 15 to transmit inbound the entire 
contents of the device's screen buffer 16 (and perhaps 
30 the contents of its symbol buffer (s) 17). In the IBM 
3270 protocol, for example, the READ BUFFER command 
performs this function. 



35 



If the contents of the screen buffer 16 are already 
available, such a command results in inefficient use of 
telecommunications resources. The optimizer 35 may 
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include a READ BUFFER SUPPRESSION routine, e.g., as shown 
in Appendixes 5 and 30, to suppress such commands. The 
operation of this routine is generally like that of the 
QUERY SUPPRESSION routine discussed above. 

5 

Triple-Pass Symbol Buffer Optimization 

The optimizer 35 may include routines to optimize 
signals directed to programmable symbol buffers. One 
10 such routine, SYMBOL BUFFER COMMAND PROCESSING, is set 
forth in Appendixes 6 through 12. 

The SYMBOL BUFFER COMMAND PROCESSING routine 
operates generally in the manner of the optimizing system 
15 of the '137 patent; it includes an advantageous approach 
to handling devices that support multiple color-plane 
loading. 

The SYMBOL BUFFER OPTIMIZATION routine (called by 
20 the SYMBOL BUFFER COMMAND PROCESSING routine) performs 
its optimizing scanning of three difference-map color 
planes (red, blue, green) in a manner to minimize the 
size of the outgoing data signal. (Scanning of 
difference maps is done to locate points where the 
25 intended state of the peripheral device 15 1 s buffers 
differ from the present state of those buffers, i.e., 
where changed-character sequences exist.) 

The SYMBOL BUFFER OPTIMIZATION routine performs a 
30 total of seven scanning passes: a triple-plane pass to 
pick up all three- color (i.e., white) changed-character 
sequences; three successive dual-plane passes to pick up 
all two-color (turquoise, yellow, pink) changed-character 
sequences; and three successive single- plane passes to 
35 pick up all one-color (red, green, blue) changed- 
character sequences. 
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f This approach may result in longer computation time 
than a single scan of each of the three planes. However, 
it can advantageously minimizes the number of commands 
5 (e.g. r LOAD PROGRAMMED SYMBOLS structured fields in the 
IBM 3270 protocol) that must be written. In the IBM 3270 
protocol, for example, for a white changed-character 
sequence, a single LOAD PROGRAMMED SYMBOLS structured 
field can include a command which specifies changing all 
10 three color planes at that address. This is advantageous 
over scanning each plane separately, where three separate 
such structured fields (one for each color plane) must be 
written for a white changed- character sequence. 

15 ' Svmbol-Sortina Optimization 

Sorting of a programmed symbol set in order of 
symbol value, prior to optimization as described above, 
is sometimes advantageous. The advantage arises when (1) 

20 a host unit 25 orders the downloading of a programmed 
symbol set to a peripheral device 15, (2) many of the 
programmed symbol bit-mapped images are the same as 
before, but (3) the still-the-same images are designated 
for storage in different slots within the peripheral 

25 device 15' s symbol buffer than before. Without sorting, 
a programmed symbol image is wastefully downloaded to a 
peripheral device 15, even though the same image is 
already present at the device in a different slot within 
the symbol buffer. 

30 

The sorting process (not shown in the Appendixes) is 
accomplished by creating (1) a map of the present state 
of the bit-mapped symbol images stored in the different 
slots of the symbol buffer, identified by slot 
35 designator; and (2) a similar map of the symbol buffer as 
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it would exist after receipt of the outgoing signal 
generated by the host unit 25. 

The maps are then searched for possible commonality 
5 of bit- mapped symbol images between pairs of slots in 
the respective maps. For example, a slot 5 in the 
present-state map may contain the same bit-mapped symbol 
image as a slot 8 of the intended- state map. 
Retransmission of this symbol image would be wasteful of 
10 telecommunications resources. 

It will likely be advantageous to sort each map, 
e.g., in ascending order of symbol value, prior to 
commencing the search. (The pattern of on- and off bits 
15 in the bit-mapped symbol image can be treated as a binary 
symbol value and sorted accordingly.) 

A variety of search techniques may be used, as will 
be appreciated by those of ordinary skill having the 

20 benefit of this disclosure. For example, the value of a 
symbol image in the sorted intended-state map may be used 
as the search target in a scan of the present-state map; 
if the scanned values in the present-state map become 
greater than the value of the target, the search has 

25 failed as to that target. 

Whenever such commonalities (and potential waste) 
are found, the optimizer 35 substitutes the existing slot 
designator (slot 5) in the new outgoing signal in place 

30 of the slot designator specified by the host unit 25 

(slot 8) . This substitution causes designator conflicts 
if the host unit 25 also used the existing slot 
designator (slot 5) to designate a different symbol 
image; a suitable hashing-type algorithm is therefore 

35 used to prevent such conflicts. 

i 
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Image Alteration - General Description 

The optimizer 35 may alter the map(s) of the screen 
buffer 16 to permit implementation of additional optimi- 
5 zation techniques. (See Appendixes 16-21* ) Generally, 

this alteration entails overwriting certain fields in the 
map of the intended information content of the screen 
buffer 16 to permit more efficient information 
transmiss ion . 

10 

Both the present-state map (which represents the in- 
fer mat ion content of the peripheral device 15 r s buffers 
as "per- ceived" by the host unit application/ program 20) 
and the intended- state map are so altered just prior to 
15 the exclusive-or generation of a difference map (see 

Figure 2). For integrity purposes, the only fields that 
are so altered are protected fields (i.e., fields that 
cannot be modified by a user at the peripheral device 
15) . 

20 

Specific alterations to the map are discussed in 
more detail below* 

Blank-to-Null Conversion 

25 

One of the routines that may be called by the IMAGE 
ALTERATION routine is the BLANK— TO— NULL CONVERSION 
routine (Appendix 17) . 

30 Blanks and nulls usually have the same appearance 

(i.e., no appearance at all) on a display screen. 
Therefore, if a run of characters to be transmitted to a 
peripheral device 15 consists entirely of intermingled 
blanks and nulls, it is advantageous to convert the run 

35 to a homogeneous sequence, thus allowing the use of a 
repeat-to- address command. 
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(As those of ordinary skill are aware, a repeat-to- 
address command instructs the peripheral device 15 to 
display a specified number of a particular character, 
5 usually at a savings in signal length. For example, such 
a command may require 5 characters to instruct the 
peripheral device 15 to display 27 consecutive spaces, 
plainly a savings of 22 characters in the signal.) 

10 To this end, the BLANK-TO-NULL CONVERSION routine 

converts all protected-f ield blanks in the map of the 
screen buffer 16 to nulls. 

An exception is made in certain systems in order to 
15 maintain transparency with certain screen-print routines. 
In such systems, when a screen is printed, the printing 
of lines on the screen having no characters other than 
nulls is suppressed. Thus, if a screen is displaying 25 
lines, and one line contains all nulls, that line would 
20 not be printed. 

To maintain transparency, the BLANK-TO -NULL 
CONVERSION routine keeps track of screen line boundaries. 
If a line on a screen consists entirely of characters 

25 which would be converted to nulls, and at least one blank 
character, then at least one blank character is left in 
the intended-state map at a location "on" that line. 
Thus, if the screen image resulting from the outgoing 
signal generated by the optimizer 35 is printed, the 

30 printed screen image will reflect null-line suppression 
if and only if the outgoing signal initiated by the host 
unit applications program 25 would have produced such a 
screen image. /j 

35 
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Dark Field Elimination 

» 

Another image-altering routine may be a DARK FIELD 
ELIMINATION routine (Appendix 18) . 

Some host unit application programs 25 include one 
or more "dark fields" in an outgoing signal. As shown in 
Figure 6, a dark field is typically a string of 
characters (e.g., an error message) that are downloaded 
to a peripheral device 15 for writing to the screen 
buffer 16 , but are delimited by a non- display field 
attribute (shown as PDFCS in Figure 6) • 

The characters in the dark field are thus present in 
15 the screen buffer 16. Because of the non-display 

attribute, however, they are not visible on the screen of 
the peripheral device 15. 



10 



20 



A dark field can be activated, so to speak, by 
overwriting the non-display attribute with a suitable 
display attribute (e.g., an attribute that causes the 
error message, already in position, to be suddenly 
displayed in flashing characters, in red, etc.). If a 
host unit application program 25 is also designed to 
25 refresh the screen buffer 16 every time an outgoing 

signal is transmitted, then the repetitive transmission 
of such a dark field is inefficient. 

The optimizer 35 may be designed to perform a DARK 
30 FIELD ELIMINATION routine (Appendix 18) to prevent any 
transmission of a protected dark field. 

The dark field may subsequently be activated by the 
host unit 25 through initiation of a suitable outgoing 
35 signal. It will be apparent to those of ordinary skill 

having the benefit of this disclosure that in this event, 
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the dark field will appear in the difference map as a 
sequence of non-null characters. Its contents will 
therefore be transmitted to the peripheral device 15 as 
part of the new outgoing signal constructed by the 
5 optimizer 35. 

Field Merge 

A FIELD MERGE routine may be called by the IMAGE 
10 ALTERATION routine. 

As shown in Appendix 19, if two successive protected 
fields have the same field attribute byte, the field 
attribute byte for the second protected field is 
15 redundant and can be eliminated. 

Device-Specific Attribute Elimination 

For some peripheral devices 15, e.g., printers , the 
20 attribute byte essentially serves no purpose. The 

DEVICE- SPECIFIC ATTRIBUTE ELIMINATION routine (Appendix 

20) checks previously-stored information (see 
INITIALIZATION (OUTGOING) routine, Appendix 2) to 
determine whether the peripheral device 15 associated 

25 with the particular communications session requires 

attributes. If no attributes are required, the routine 
overwrites all character sequences designating such 
attributes with nulls. 

30 Null Field Attribute Elimination 

A NULL FIELD ATTRIBUTE ELIMINATION routine (Appendix 

21) may be called by the IMAGE ALTERATION routine. 

35 As noted above, null characters ordinarily are not 

visible on a screen. Thus, if a protected field consists 
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of nulls (e.g., which may result from the BLANK-TO-NULL 
CONVERSION routine) , any attributes defining the field 
are superfluous, provided of course that the attribute 
does not follow (and therefore delimit) an unprotected 
5 fieTd. For example, nulls do not appear as bright 

characters, and so therefore a bright attribute for a 
null field is surplusage in an outgoing signal. 

The NULL FIELD ATTRIBUTE ELIMINATION routine 
10 searches the map in question and overwrites any attribute 
bytes for null fields with null characters. 

MPT Reset Voting 

15 A RESET-MDT VOTING routine (Appendix 22) may be 

called from the IMAGE ALTERATION routine. To be precise, 
the RESET-MDT VOTING routine does not involve alteration 
of a buffer map, and therefore may equally well be called 
from the MAIN (OUTGOING) routine. 

20 

Additional background information can appropriately 
be mentioned here. As described in more detail in the 
'137 patent, an MDT is typically a specific bit flag 
within a field attribute byte. This flag is ordinarily 

25 set when the associated field is modified; it may also be 
preset by a host unit application program 25 as part of 
an outgoing data signal (thus "premodifying" the' 
associated field as premodif ied) . If a field is 
premodified, t^ie peripheral device 15 will transmit its 

30 contents inbound whether or not the user of the 

peripheral device 15 has actually modified the field. 

Some protocols (e.g., the IBM 3270 protocol) provide 
that an MDT at a peripheral device 15 remains set until 
35 cleared. The %£>T can typically be cleared either by an 

MDT reset command or by a buffer-erase command, in either 
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case transmitted outbound by a host unit applications 
program 20. 

Thus, once a field is modified (or premodified) , its 
5 con tents will be transmitted inbound with every subse- 
quent inbound signal — whether or not those contents 
have been modified in connection with the subsequent 
signals after the first one — until the MDT is cleared. 
In effect, such a field, with a left- over MDT that 
10 remains, becomes "premodified" with respect to all 
subsequent signals until the MDT is cleared. 

As described in the 1 137 patent and the '150 
application, the optimizer 35 clears the MDT for certain 
15 premodified fields. This may require the optimizer 35 to 
generate a signal to clear any left-over MDTs that remain 
set . 

The MDT-reset command is a quick , cheap, brute-force 
20 way to clear all MDTs at the peripheral device 15. Its 
use may result in a net increase in the size of the 
outgoing signal, however: in some circumstances, certain 
MDTs must remain set, and so if an MDT-reset command is 
used, those MDTs must be set again. 

25 

It may be that more MDTs are to be set again after 
an MDT- reset command than would need to be cleared if an 
MDT-reset command were not used. In such a situation, 
the size of the outgoing signal is likely to be shorter 
30 if an MDT-reset command is not used. 

The RESET -MDT VOTING routine (Appendix 22, 24) 
permits selective use of the MDT reset command. The 
routine examines all field attribute bytes in the 
35 present-state and intended-state maps of the screen 

buffer 16. It counts the state changes, if any, between 
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the present state and the intended state, of the MDTs in 
the various field attribute bytes. 

If fewer MDTs go from set to cleared than from 
5 cleared (or set) to set, then a shorter data stream will 
result from not using an MDT-reset command, and instead 
individually clearing the desired MDTs. Conversely, if 
more MDTs must be cleared than set, it more economical to 
use an MDT-reset command, and then to individually set 
10 again any MDTs that need it. 

Signal Generation r Screen) 

When image alteration is complete, the optimizer 35 
15 performs a SIGNAL GENERATION (OUTGOING-SCREEN) routine 
(Appendix 23). This routine makes two successive calls 
to a TEST SIGNAL routine, which generates two test 
signals for potential transmission to the peripheral 
device 15; the shorter of the two signals is ultimately 

2 0 transmitted . 

The first call to the TEST SIGNAL routine is 

preceded by the writing of an erase-buffer command to the 
first test signal. This means that the first test signal 
25 must completely rewrite the screen buffer 16 with the 
contents of the intended-state map. 

The second call to the TEST SIGNAL routine is not 
preceded by writing an erase-buffer command. In the 

3 0 second test signal, therefore, every character sequence 

in the screen buffer 16 that is to be changed must be 
individually modified with a set-buffer- address and a 
write command. 

35 Before making these calls to the TEST SIGNAL 

routine, the SIGNAL GENERATION (OUTGOING-SCREEN) routine 
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performs an MDT-RESET VOTE COUNT routine (Appendix 24) to 
determine whether or not to use an MDT-reset command. 

Test Signal Generation 

5 

The TEST SIGNAL routine (Appendix 25) may call a 
NULL/ NON- NULL STRING DELIMITATION routine (Appendix 26) 
to scan the intended-state map (if an erase-buffer 
command is used) or the difference map in search of 
10 triplets of character sequences SI, S2, and S3. As shown 
in Figure 7, each such triplet consists of two sequences 

51 and S3 of non-null characters separated by a sequence 

52 of null characters. 

15 The TEST SIGNAL routine then may call a TRIAL 

GENERATION routine (Appendix 27) to generate two trial 
signals for each triplet so located. In the first trial 
signal, the TRIAL GENERATION routine treats the triplet 
as a single character sequence: it calls an OUTPUT 

20 STRING GENERATION routine (Appendix 28) to write a single 
set-buffer-address command for the triplet, then copy all 
characters (both non-null and null) from the map being 
scanned to the trial signal. As explained in the f 137 
patent, all characters in the map that represent a field 

25 attribute or other code sequence are reconverted back to 
the proper code sequence in the process. 

In the second trial signal, the TRIAL GENERATION 
routine deals with non-null sequences SI and S3 in the 
30 same manner, but separately, with each of SI and S3 being 
the subject of a call to OUTPUT STRING GENERATION. 
Whichever of the two trial signals is shorter is used as 
the signal for that triplet. 

35 The OUTPUT STRING GENERATION routine- may be designed 

to test each sequence for multiple consecutive 
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occurrences of the same character, and in such event to 
utilize a repeat-to-address command in lieu of the 
multiple occurrences* Such a test and repeat-to-address 
command are conventional and are not described here. 

5 

Device Display Mask 

The OUTPUT STRING GENERATION routine utilizes a 
device display mask to take advantage of information 
10 known about the display characteristics of the peripheral 
device 15. 

Many peripheral devices can process extended- 
attribute commands that designate, e.g., different colors 

15 for the screen buffer 16. Not all such devices can 

display all extended attributes, however. For example, a 
particular device may be able to accept an extended- 
attribute command designating the color orange for 
display, but may only be able actually to create a black- 

20 and-white display. 

The OUTPUT STRING GENERATION routine tests for this 
possibility. In doing so, it looks up a device-display 
mask created by the SIGNAL GENERATION (INCOMING) routine. 

25 Upon receipt of an incoming signal containing a response 
to a query command (see QUERY SUPPRESSION routine) , the 
SIGNAL GENERATION (INCOMING) routine builds a device- 
display bit mask to indicate the extended attributes, if 
any, that can be displayed by the particular peripheral 

30 device 15. 

In writing an output string from a character 
sequence, the OUTPUT STRING GENERATION routine determines 
whether a particular character represents a command 
35 character sequence. If so, and if the sequence is an 

extended-attribute command, it performs an AND operation 

i 

I 

i 
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between the command and the device-display mask. The 
result represents those extended attributes specified by 
the output signal that are actually displayable at the 
peripheral device 15. 

5 

Creation of Substitute Signal 

When optimization of screen-buffer and symbol-buffer 
signal components is complete, the optimizer 35 generates 

10 a substitute signal from the components created by the 
optimization process. A convenient way to generate a 
substitute signal is to scan the original signal 
(generated by the host unit application program 25) and, 
for each component part of the original signal, substi 

15 tute the new component part(s) generated by the optimizer 
35. 

Buffer Wraparound 

20 The substitute signal itself may be further 

optimized to take advantage of buffer wraparound 
features . 

In some systems, a wraparound occurs if characters 
25 are written to the screen buffer 16 beginning near the 

end of the buffer, and continuing past the end: instead 
of being lost, the characters written past the end of the 
buffer are wrapped around to the beginning of the buffer. 
This can be advantageous in writing to the beginning of 
30 the buffer. 

Ordinarily, such writing is accomplished by 
including a set- buffer-address command in the outgoing 
(or substitute) signal, designating the beginning of the 
35 buffer as the location to commence writing characters. 



SUBSTITUTE SHEET 



WO 90/01191 



PCI7US89/03245 



-24- 

. Consider , however, the situation where, after 
receipt by the peripheral device 15 of the substitute 
signal, both the beginning and the end of the screen 
buffer 16 each contain an arbitrary sequence of 
characters to be written. Ordinarily, two set- buffer- 
address commands will be generated, one to write to the 
beginning of the buffer, one to write to the end. 



The optimizer 35 takes advantage of buffer 
10 wraparound capability by testing whether the above 
situation exists. If so, the substitute signal is 
altered so that the first set-buffer- address command in 
the signal is removed, and the characters to be written 
to the beginning of the buffer are moved within the- 
15 signal to follow the characters to be written to the end 
of the buffer. 

The beginning characters will thus be written to the 
"end" of the buffer, but will wrap around to the 

2 0 beginning. The size of the substitute signal is 

consequently reduced by the size of the set-buf fer- 
address designating the beginning of the buffer. 
I 

i This approach can be particularly advantageous when 
25 both the end and the beginning of the screen buffer 16 
contain runs of identical characters, perhaps with 
neither separate run being big enough to justify 
compression using a repeat-to-address command. By 
utilizing the wraparound feature, a repeat-to-address 

3 0 command may be usable where it was not before. 



Signal Routing 

After completion of the foregoing signal processing, 
35 the substitute signal generated by the optimizer 35 is 
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delivered to the signal routing unit 30 for routing to 
the peripheral device 15. 

* * * 

5 

It will be appreciated by those skilled in the art 
having the benefit of this disclosure that this invention 
is believed to be capable of application in other 
situations in which the hardware and software work in 

10 substantially the same way to achieve essentially the 
same result. Some of these situations have been 
expressly described here (as examples and not as 
limitations) , and others will be recognized by those of 
skill. Accordingly , this description is to be construed 

15 as illustrative only and as for the purpose of teaching 
those skilled in the art the manner of carrying out the 
invention. 

It is also to be understood that various 
20 modifications and changes may be made, e.g., in the 

shape, size, and arrangement of components, operating 
steps, and so forth, without departing from the spirit 
and scope of the invention as set forth below in the 
claims. 

25 

For example, on some computer systems it may be 
preferable from a cost-effectiveness standpoint to adapt 
preexisting macros or modules to accomplish the functions 
described here, albeit perhaps in a different order than 
30 described. 

Or, in some circumstances it may be desired to 
implement the system in conjunction with an existing 
computer program system of another type, with the 
35 possible result that the functions described here may be 
merged with other functions. 
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The system described here is organized in various 
routines; on some computer systems, it may be preferable 
to implement the system's functions through the use of, 
e.g., macros to avoid the overhead associated with a 
subroutine call. 



10 



It is intended that the following claims be 
interpreted to embrace all such modifications and 
changes . 
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Appendix 1 
TABLE OF CONTENTS 

1. TABLE OF CONTENTS 

2. MAIN (OUTGOING) routine 

3. INITIALIZATION (OUTGOING) routine 

4. QUERY SUPPRESSION routine 

5. READ BUFFER SUPPRESSION routine 

6. SYMBOL BUFFER COMMAND PROCESSING routine 

7. INIT SYMBOL BUFFER routine 

8. UPDATE SYMBOL BUFFER routine 

9. SYMBOL BUFFER OPTIMIZATION routine 

10. MULTI-PASS COLOR SCHEME data structure 

11. DIFFERENCE SCAN (SYMBOL) routine 

12. COLOR-MATCHED SYMBOL TEST routine 

13. SCREEN BUFFER COMMAND PROCESSING routine 

14. INIT SCREEN BUFFER (OUTGOING) routine 

15. UPDATE SCREEN BUFFER (OUTGOING) routine 

16. IMAGE ALTERATION routine 

17. BLANK-TO-NULL CONVERSION routine 

18. DARK FIELD ELIMINATION routine 

19. FIELD MERGE routine 

20. DEVICE-SPECIFIC ATTRIBUTE ELIMINATION routine 

21. NULL FIELD ATTRIBUTE ELIMINATION routine 

22. RESET-MDT VOTING routine 

23. SIGNAL GENERATION (OUTGOING-SCREEN) routine 

24. MDT-RESET VOTE COUNT routine 

25. TEST SIGNAL routine 

26. NULL/NON-NULL STRING DELIMITATION routine 

27. TRIAL GENERATION routine 

28. OUTPUT STRING GENERATION routine 

29. MAIN (INCOMING) routine 

30. SIGNAL GENERATION (INCOMING) routine 
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Appendix 2 
MAIN ( OUTGOING 1 routinp 

For each outgoing signal: 

A. Get outgoing signal 

B. Perform INITIALIZATION (OUTGOING) routine 

C. Perform QUERY SUPPRESSION routine 

D. Perform READ BUFFER SUPPRESSION routine 

E. Perform SYMBOL BUFFER COMMAND PROCESSING routine 

F. Perform SCREEN BUFFER COMMAND PROCESSING routine 

G. Generate substitute signal from Substitute-Signal data 
structure and pass to signal routing unit 

H. (END) 
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Appendix 4 



QUERY STTPPPfgcj ow mul-ir^ 

[Called from MAIN (OUTGOING) routine] 
1) Yes: 

SJ2£f™ teStS 15 Quer y- A1 ^y-C 01 npleted 

a) Yes: 

1) Save contents of qc 

2) Set Query-Sent flag 

3) Q^ii^-? 1 ? 1111 ?^ quer y c o=»and MQC to 
Substitute-Signal data structure 

4) RETURN 

b) No (Query-Already-Completed flag cleared) : 

1} JSSStS.* 0 Substitute "Signal data 
2) RETURN 

2) No (no query conunand in outgoing signal) : return 



* 
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Appendix 5 



READ BUFFER SUPPRES SION rniH-j n . 

[Called from MAIN (OUTGOING) routine] 



1) Yes: 

a) set Read-Buffer flag 

b) Write Read-Modified-Buffer command to 
Substitute-Signal data structure 

2) No: Continue 




ttgoing signal include a 
RBC? 



B. RETURN 
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Appendix 6 
SYMBOL BUFFER COMMAND PROCBRHt kc ranHno 

"m^ndst"* Si9nal includes ^ symbol-buffer modification 
A. Perform INIT SYMBOL BUFFER routine 

B * J°.L«« C £, symbol-buffer modification command, perforin 
UPDATE SYMBOL BUFFER routine perrorm 

C. For each designated color in COLOR PASS data structure 
perform SYMBOL BUFFER OPTIMIZATION routine for that ' 
etrurture C r ' thereby t0 S ^titutefIigSaf data 

D. HE TURN 
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Appendix 7 
T|ttt symbol BUFFER routine 

[Called from MAIN (OUTGOING) routine] 

A. IF-THEN-ELSE test: Do Present (Symbol) map(s) exist 
for this session? 

1) Yes: Retrieve Present (Symbol) map(s) for session 

2) No: Create null Present (Symbol) map(s) for 
session by allocating free storage 

B- Create Intended (Symbol) map(s) by copying Present 
(Symbol) map(s) to free storage 

C. RETURN 



Note: If peripheral device supports multiple 
color-plane (e.g., separate red, green, blue) symbol 
buffers, one Present (Symbol) and one Intended (Symbol) 
map is created/retrieved for each color plane 



f 
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Appendix 8 



UPDATE SXHBQL PU FFER i-nii*^ 

A. Get symbol-modifying command SMC 

B. Parse smcj 

X) ?£?S%L £SfS5 contents which syabo1 buffer < s > 

2) Determine from SMC contents the location (s) L in 
iSlifief CtiVe Sy,nb01 buffe ^> ■ °f *y£otl to S 

C. For each location L: 

1) Locate position P in Intended (Symbol) aaofsv 
corresponding to location L Y 1000 *) map(s) 

2) Modify contents of Intended (Symbol) maDfs) -t 

D. RETURN 
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Appendix 9 



SYMBOL BUFFER OPTIMIZATION routine 



[Called from MAIN (OUTGOING) routine] 

A. Go to beginning of MULTI-COLOR PASS SCHEME data 
structure 

B. While more designated pass colors remain in MULTI-COLOR 
PASS SCHEME data structures 

1) Get next designated pass color 

2) Designate Intended (Symbol) and Present (Symbol) 
maps for the principal color attribute 
corresponding to that designated pass color as the 
Intended (Principal Color) and Present (Principal 
Color) maps 

3) Designate Intended (Symbol) and Present (Symbol) 
maps for any secondary color attributes 
corresponding to that designated pass color as 
Intended (Secondary Color) and Present 
(Secondary Color) maps 

4) Label maps so designated as Designated Color maps 

5) Perform DIFFERENCE SCAN (SYMBOL) routine 

6) Continue [step B] 
E. RETURN 
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Appendix 10 



MTOTI-PASP COLOR SCHEME d„fa, rtrurtnr. 



Multi-record data structure of color attributes for 
S^SroS'pSS? 1 ™' ™* sin ^ 1 — SYMBOL BUFFER 

Principal sec. 
Color Color 
Attribute Attribute 




White Blue Red, Green 

Turquoise Blue Green 

Yellow Red Green 

Red Blue 

Blue Blue ( 

Red (none 

Green Green (none) 
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Appendix 11 



DIFFERENCE SCAN (SYMBOL) routine 



[Called from SYMBOL BUFFER OPTIMIZATION routine] 

A. Go to beginning of Designated Color maps 

B. While more symbols remain in the Designated Color maps: 

1) Get next symbols SD from Intended (Principal 
Color) and Present (Principal Color) maps, note 
location in maps as LD 

2) IF-THEN-ELSE test: are SDs in Intended (Principal 
Color) and Present (Principal Color) maps 
identical? 

a) Yes (no change to be made) : Continue [step B] 

b) No (change to be made) : 

1) Perform COLOR-MATCHED SYMBOL TEST 

routine on Designated Color maps — test 
for whether change is to be made on this 
pass 

' 2) If COLOR-MATCHED SYMBOL TEST returned 
designation of a color-matched map 
segment CMMS: 

a) Write a command to the Substitute- 
Signal data structure to cause 
downloading to peripheral device 
symbol buffer, in the designated 
pass color, of symbols contained, 
at map segment CMMS, in the 
Intended (Symbol) map 

b) Overwrite map segment CMMS of all 
Present (Symbol) maps with corres- 
ponding symbols from Intended 
(Symbol) maps 

c) Move scan pointer (in Intended 
(Primary Color) and Present (Primary 
Color) maps) ahead to end of map 
segment CMMS 

3) Continue [step B] 

C. RETURN 
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Appendix 12 
COLOR—MATCHED SYMBOL TEST routine 

[Called from DIFFERENCE SCAN (SYMBOL) routine] 

IF-THEN-ELSE test: are contents of Intended (Primary Color) 
map at location LD identical only to contents of any Intended 
(Secondary Color) maps at location LD, and not identical to 
any other Intended (Symbol) maps? 

A. Yes (designated pass color match - make change on this 
pass) : 

1) Label location LD as beginning of color-matched 
map segment CMMS 

2) Scan ahead in all Intended (Symbol) maps to locate 
a symbol that is either color-mismatched with the 
designated pass color or is both color- and 
content- matched with the Present (Symbol) maps, 
i.e. a symbol that either (i) is not a symbol of 
the designated pass color, or (ii) is a symbol of 
the designated pass color, but matches the 
corresponding symbol in the Present (Symbol) maps, 
and the corresponding symbol is also of the 
designated pass color 

3) Designate location of symbol so located as LE 

4) Calculate length of CMMS as number of symbols 
between LD (inclusive) and LE (exclusive) 

5) RETURN length of CMMS 

B. No : RETURN 



0 
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Appendix 13 



SCREEN BUFFER COMMAND PROCESSING routing 



[Called from MAIN (OUTGOING) routine] 

If outgoing signal includes any screen-buffer modification 
commands : 

A. Perform INIT SCREEN BUFFER (OUTGOING) routine to get 
Present (Screen) and Intended (Screen) maps 

B. Perform UPDATE SCREEN BUFFER (OUTGOING) routine upon 
Intended (Screen) map for each screen-buffer 
modification command 

C. Make copy of Intended (Screen) map, save copy to 
storage as Saved (Screen) map 

D. Perform IMAGE ALTERATION (OUTGOING) routine upon 
Intended (Screen) map 

E. RETURN 
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Appendix 14 
INIT SCREEN BUFFER f OUTG OING 1 routino 

[Called from SCREEN BUFFER COMMAND PROCESSING routine] 

A. IF-THEN-ELSE test: Does Saved (Screen) map exist for 
this session (i.e., was a previous outgoing or incomina 
signal processed)? 9 

1) Yes: Retrieve a copy of Saved (Screen) map for 
session and rename copy as Present (Screen) map 

2) No: Create null Present (Screen) map for session 
by allocating free storage 

B. Create Intended (Screen) map by copying Present (Screen) 
buffer to free storage 

C. IF-THEN-ELSE test: Are any image-alteration 
flags set for session (see subroutines called 
by IMAGE ALTERATION routine)? 

1) Yes: 

a) Perform the IMAGE ALTERATION 
(OUTGOING) subroutine (s) that 
correspond to the set flags, to 
alter the Present (Screen) map 

b) Clear the image-alteration flags 
for the session 

2) No: Continue 

D. RETURN " 
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Appendix 15 
UPDATE SCREEN BUFFER f OUTGOING! routine 

[Called from MAIN (OUTGOING) routine] 

A. Get screen-buffer-modifying command SBMC from signal 

B. Determine location L in screen buffer of character (s) 
to be modified as a result of SBMC 

C. Locate position P in Intended (Screen) map 
corresponding to location L 

D. Go to beginning of SBMC 

E- Modify contents of Intended (Screen) map at location P 
in accordance with modification instructions of SBMC, 

translating any commands or orders embedded in SBMC into 
nonprotocol characters 

F. RETURN 
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Appendix 16 

IMAGE ALTERATION routine 

[Called from MAIN (OUTGOING) routine] 
A. Perform BLANK-TO-NULL CONVERSION routine 
Perf orm DARK FIELD ELIMINATION 

C. Perform FIELD MERGE routine 

D. Perform DEVICE-SPECIFIC ATTRIBUTE ELIMINATION routine 

E. Perform NULL FIELD ATTRIBUTE ELIMINATION routine 

F. Perform RESET-MDT VOTING routine 

G. RETURN 



NOTE: All routines above may be performed on a single 
pass through the Intended (Screen) or Present (Screen) 
map to save processing time 
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Appendix 17 
BLANK-TO-NULL CONVERSION cgi^jj^ 

[Called from the IMAGE ALTERATION routine] 

A. Go to beginning of nap 

B. While more protected fields remain in map: 

1) Scan map to locate next protected field 

2) Convert all blank characters in protected field to 
n i*ll characters; ensure tha * no screen-image lines 
which contained blanks are converted entirely to 
nulls 

3) If any blank characters were converted, set 
Image-Alteration (Blank to Null) flag 

4) Continue [step B] 
C RETURN 
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Appendix 18 
DARK FIELD ELIMINATION ro^Hnp 

[Called from IMAGE ALTERATION routine] 

A. Scan map for attribute character sequence (PDFCS) 
designating protected "dark" field 

B. For each protected darJc field found: 

1) Note the first character following the PDFCS as 
the beginning location of a protected dark field 

2) Scan ahead in map for the next field attribute 
character sequence, delimiting the end of the dark 
field 

3) Overwrite dark field with nulls 

4) Set Image-Alteration (Dark Field) flag 

5) Continue scan [step A] 

C. RETURN 



ft 

0 
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Appendix 19 
FIE1P MEFGE rputipe 

[Called from IMAGE ALTERATION routine] 

A. Initialize Attribute-Previous data structure to 
indicate beginning-of-map (i.e., no attribute) 

B. Set pointer to beginning of map 

Scan map (moving the pointer as scan progresses) to 
locate next field attribute character sequence (FACS) 

D. For each FACS found: 

1) Designate as Attribute-Current the attribute value 
of the FACS 

2) IF-THEN-ELSE test (two-part): 

Is Attribute-Current equal to the attribute value 
of Attribute-Previous, 

and 

Does Attribute-Current designate a protected 
field? 

a) Yes: 

1) Overwrite the map to eliminate the field 
attribute character sequence designated 
by Attribute-Current 

2) Set Image-Alteration (Field Merge) flag 

3) Continue [step C] 

b) No: 

1) Make Attribute-Current the new 0 
A 1 1 r ibu t e -Pr e vi ous 

2) Continue [step C] 

E. RETURN 
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Appendix 20 

PEVICE-SPPCTFTC ATTRIBUTE ELIMINAT ION roiit<n. 
[Called from IMAGE ALTERATION routine] 

A. Go to beginning of map 

B. While more fields remain in map: 

1) Scan map to locate next field 

2) Overwrite field attribute (s) with null character (s) 

3) If any field attributes were overwritten, set 
Image-Alteration (Device-Specific) flag 

4) Continue [step B] 

C. RETURN 



SUBSTITUTE SHEET 



WO 90/01191 PCT/US89/03245 

47 

Appendix 21 
PULL FIELD ATTRIBUTE ELIMINATION ronH'^ 

[Called from IMAGE ALTERATION routine] 

A. Initialize Attribute-Previous data structure to 
indicate beginning-of-map 

B. Initialize Attribute-Current data structure and set 
All-Nulls flag 

C. Set pointer to beginning of map 

D. Scan map (moving the pointer as scan 
progresses) to locate next field attribute character 
sequence (or end-of-map indicator) 

E. If nonnull or nonspace character is detected durina 
scan, clear All-Nulls flag 

F. When field attribute character sequence (or end-of-maD 
indicator) is found: * 

IF-THEN-ELSE test: is the All-Nulls flag set? 
1) Yes: 

I F-THEN-ELS E test: does the Attribute-Previous 
data structure still indicate beginning-of-map? 

a) Yes: Continue [step D] 

b) No: 

1) Overwrite map to eliminate 

field attribute character sequence 
represented by Attribute-Previous 

2) Set Image-Alteration (Null Field 
Attribute Elimination) flag 

3) Make Attribute-Current the new 
Attribute-Previous 

2) No: Reset All-Nulls flag and continue (step D) 
G. RETURN 
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Appendix 22 



RESET-MDT VOTING routine 



[Called from IMAGE ALTERATION (OUTGOING) routine] 

A. Initialize Reset-Vote counter and NoReset-Vote counter 
at zero value 

B. SWITCH test: 

1) Compare each field attribute in Intended (Screen) 
map with corresponding field attribute in Present 
(Screen) map (i.e., determine what if any state 
change has occur ed) 

2) For each such field attribute,, increment the 
Reset-Vote or NoReset Vote counter in accordance 
with the following table: 



CASE: 



ACTION: 



Field attr. 
in Present 
(Screen) map 



AND 



Field attr. 

in Intended THEN 

(Screen) map 



Premodified 
Premodified 
Unpremodified 
Unpremodified 



Unpremodified 
Premodified 
Unpremodified 
Premodified 



Increment 

Which 

Counter? 



Reset-Vote 

NoReset-Vote 

(none) 

NoReset-Vote 



C. RETURN 
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Appendix 23 
SIGNAL GENERATION ( OUTGOING-SCREE N) routine 

[Called from MAIN (OUTGOING) routine] 

A. Perform MDT-RESET VOTE COUNT routine 

B. Set Erase-Buffer flag 

C. Perform TEST SIGNAL routine, utilizing Intended 
(Screen) map as operand, to generate New-Signal (Erase 
Yes) data structure 

D* Clear Erase-Buffer flag 

E. If Use-Reset flag is set, write an MDT-reset command to 
the Substitute-Signal data structure 

F. Exclusive-or (XOR) the Intended (Screen) map onto the 
Present (Screen) map to generate a Difference (Screen) 
map 

G. Perform TEST SIGNAL routine, utilizing both Difference 
(Screen) and Intended (Screen) maps as operands, to 
generate New-Signal (Erase No) data structure 

H. Write the shorter of the two test signals (from the 
New-Signal (Erase) and New-Signal (No Erase) data 
structures) to the Substitute-Signal data structure 

I. RETURN 
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Appendix 24 
MDT-RESET VOTE COUNT caa^pg 

[Called from SIGNAL GENERATION (OUTGOING-SCREEN) routine] 
IF-THEN-ELSE test: Reset-Vote > NoReset-Vote? 

A. Yes: 

1) Set Use-Reset flag 

2) Scan Present (Screen) map, change all 
"premodified" field attribute character 
sequences to "unpremodif ied" field attribute 
character sequence 

COMMENT: Step A (2) — > any premodified field 

attributes in the Intended (Screen) map will 
automatically mismatch against the Present 
(Screen) map upon XOR (see SCREEN BUFFER 
COMMAND PROCESSING routine) , and thus be 
guaranteed to generate a nonnull character in 
the Difference (Screen) map (see SIGNAL 
GENERATION (OUTGOING-SCREEN) routine " 

B. No: 



1) Clear Use-Reset flag 

2) Scan Present (Screen) map, change all 
"premodified" field attribute character 
sequences to the in-doubt character 

COMMENT: Step B(2) forces a mismatch on all 
premodified field attributes — > any 
"left-over" premodified fields at the device 
screen buffer will be turned off by the 
outgoing signal, even though they remain 
unchanged from the previous incoming signal 
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Appendix 25 



TEST SIGNAL routine 



[Called from SIGNAL GENERATION (OUTGOING - SCREEN) routine] 



A. IF Erase-Buffer flag is set: 

1) THEN use Intended (Screen) map as Scan map; 

2) ELSE use Difference (Screen) map as Scan map 

B. While more non-null characters remain in Scan map: 

1) Scan forward in Scan map, locate next non-null 
character 

COMMENT: In systems supporting multiple map 
planes (e.g., for extended attribute bytes), a 
"non-null character" at a given position is one 
that is non-null at that position in any Scan map 
plane 

2) Perform NULL/NON-NULL STRING DELIMITATION routine 
to obtain boundaries of three consecutive strings 
SI, S2, S3 in Scan map (string SI beginning with 
the non-null character found) 

3) Perform TRIAL GENERATION routine, using strings 
SI, S2, and S3 as operands, to write Alt-Signal 1 
and Alt-Signal 2 

4) Write shorter of Alt-Signal 1 and Alt-Signal 2 to 
Substitute-Signal data structure 

5) Move scan pointer to end of string S3 

6) Continue scan [step B] 
C. RETURN 



I 
i 
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Appendix 29 
MAIN CHIggmMSl routinA 

For each incoming signals 

A. Get incoming signal 

B. Locate Saved (Screen) map associated with session 

C. Apply incoming signal to Previous (Screen) map to 
generate Present (Screen) map; 

All command or order character sequences to be 
represented in Present (Screen) map as unique symbols 

D. Perform SIGNAL GENERATION (INCOMING) routine 

Generate substitute signal from Substitute-Signal data 
structure and pass substitute signal to host unit 

F. Save Present (Screen) map for future reference 

G. END 
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Appendix 26 



NULL/NON-NULL STRING DELIMITATION routing 



[Called by TEST SIGNAL routine] 



A. Note starting address of non-null string SI that begins 
with non-null character found by calling routine 

B. Scan ahead in Scan map for next null character; note 
this character as end of non-null string SI and 
beginning of null string S2 

COMMENT: In systems supporting multiple Scan map planes 
(e.g., for extended attribute bytes), a "null character" 
at a given position must be null at corresponding 
positions in all Scan map planes 

C. Scan ahead in Scan map for next non-null character; 
note this character as end of null string S2 and 
beginning of second non-null string S3 

COMMENT: In systems supporting multiple map planes 
(e.g., for extended attribute bytes), a H non-null 
character" at a given position is one that is non-null 
at that position in any Scan map plane 

D. Scan ahead in Scan map for next null character? note 
this character as end of non-null string S3 

E. RETURN 
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Appendix 27 



TRIAL GENERATION routine 



[Called from TEST SIGNAL routine] 



A, Generate Alt-Signal 1: 

1) Initialize memory for Alt-Signal 1 

2) Define Scan-String as string in Intended (Screen) 
map corresponding to consecutive strings SI, S2, 
and S3 in Scan map (treated as a single concatena- 
ted string) 

3) Perform OUTPUT STRING GENERATION routine, utili- 
zing Scan-String as operand? write resulting 
Output-String to Alt-Signal 1 

B. Generate Alt-Signal 2: 

1) Initialize memory for Alt-Signal 2 
. 2) Generate signal from first non-null string SI: 

a) Define Scan-String as string in Intended 
(Screen) map corresponding to non-null string 
SI in Scan map 

b) Perform OUTPUT STRING GENERATION routine, 
utilizing Scan-String as operand; write 
resulting Output-String to Alt-String 2 

3) Generate signal from second non-null string S3: 

a) Define Scan-String as string in Intended 
(Screen) map corresponding to string S3 in 
Scan map 

b) Perform OUTPUT STRING GENERATION routine, 
utilizing Scan-String as operand; append 
resulting Output-String to Alt-String 2 

C. RETURN 
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Appendix 28 

PVTPVT STRINg gENERATIPN rwrtin* 
[Called from TRIAL GENERATION routine] 

A. Initialize memory for Output-String 

B. Write set-buffer-address to Output-String designating 
address of Scan-String as location to begin writing to 
buffer 

C. While more characters remain in Scan-String: 

1) Get next character C from Scan-String 

2) IF-THEN-ELSE test: Is C a command code? 

a) YES: 

1) Translate C into corresponding command 
character sequence CCS 

2) If CCS is an extended-attribute code, 
overwrite CCS with result of ANDing CCS 
with Device-Display mask 

3) Append CCS to Output-String 

b) NO: Append C to Output-String 

3) Continue [step C] 
C. RETURN 
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Appendix 30 

SIQVhL <?ENERATIQN flNCPMIPg) ratine * 

A. IF-THEN-ELSE test: Does incoming signal include a 
reply QCR to a query command (QC or MQC - see QUERY 
SUPPRESSION routine)? 

1) Yes: 

a) IF-THEN-ELSE tests Is 
Query-Already-Completed flag set? 

1) Yes: Continue 

2) No: 

a) Copy QCR to Query-Reply data 
structure 

b) Set Query-Already-Completed flag 

c) Build and save Device-Display 
mask for later use 

b) Write contents of Query-Reply data structure 
to Substitute-Signal data structure 

2) No: Continue 

B. IF-THEN-ELSE test: Is Read-Buffer flag (see READ 
BUFFER SUPPRESSION routine) set? 

1) Yes: 

a) Perform OUTPUT STRING GENERATION routine, 
utilizing entire contents of Intended 
(Screen) map as Scan-String 

b) Write resulting Output-String to 
Substitute-Signal data structure 

2) No: While more modified fields remain in Intended 
(Screen) map - 

a) Get contents of next modified field 

b) Perform OUTPUT STRING GENERATION routine, 
utilizing contents of modified field of 
Intended (Screen) map as Scan-String 

c) Append resulting Output-String to 
Substitute-Signal data structure 

C RETURN 
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CLAIMS: 

1. A computer device comprising program 
instruction statements which, when executed by a 
programmable machine, result in the performance of the 
following steps: 

intercepting an outgoing signal directed to a 
peripheral device; 

testing the outgoing signal for the presence of 
a device-capability query signal; 

if a device-capability query signal is present 
15 within the outgoing signal, checking a table for the 
presence of information responsive to the device- 
capability query signal; 

if said table includes said information, 
20 constructing a new outgoing signal with a minimal query 
signal and directing said new outgoing signal to said 
peripheral device; 

intercepting an incoming signal from said 
25 peripheral device; 

if said table includes said information, 
constructing a new incoming signal including said 
information. 



30 



2. A computer device comprising program 
instruction statements which, when executed by a 
programmable machine, result in the performance of the 
following steps: 



35 
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intercepting an outgoing signal directed to a 
peripheral device; 

testing the outgoing signal for the presence of 
5 a read- buffer signal; 

if a read-buffer signal is present within the 
outgoing signal , checking a present-state map for the 
presence of information responsive to the read-buffer 
10 signal; 

if said present-state map includes said 
information , constructing a new outgoing signal with a 
minimal read signal and directing said new outgoing 
15 signal to said peripheral device; 

intercepting an incoming signal from said 
peripheral device; 

20 if said table includes said information, 

constructing a new incoming signal including said 
information. 

3* A computer device operable in conjunction with 
25 an optimizer that scans a difference map comprising a 
plurality of color plane, 

said computer device comprising program 
instruction statements which, when executed by\ a 
30 programmable machine, result in the performance of the 
following steps: 

scanning a primary color plane in search of a 
specified character; 
35 j 
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if an instance of said specified character is 
found at a hit location, checking zero or more secondary 
color planes at said hit location for the presence of 
said specified character; 

5 

if said specified character is present in all 
said secondary color planes at said hit location, 
performing a specified action, 

10 4. A computer device operable in conjunction with 

an optimizer that processes a map, 

said computer device comprising program 
instruction statements which, when executed by a 
15 programmable machine, result in the performance of the 
following steps: 

scanning said map for a protected dark field; 

and 

20 

overwriting said protected dark field with null 
characters . 

5. A computer device comprising program 
25 instruction statements which, when executed by a 

programmable machine, result in the performance of the 
following steps: 

intercepting an outgoing signal directed to a 
30 peripheral device, said outgoing signal including zero or 
more display attributes; 

checking a table to determine whether said 
peripheral device supports said display attributes; and 

35 
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if said peripheral device does not support 
display attributes, constructing a new outgoing signal 
with no said display attributes and directing said new 
outgoing signal to said peripheral device. 

5 

6. A method for optimizing a process of 
downloading a plurality of programmable symbols, each 
having a binary value, to respective slots in a symbol 
buffer of a peripheral device, each said slot identified 
10 by a designator, said method comprising the steps of: 

generating a present-state map of the contents 
of said slots and an updated-state map of said contents 
as are expected to exist after said downloading; 

15 

searching said present-state map and said 
updated-state map for commonalities of binary values 
without commonality of corresponding designator; and 

20 replacing each said corresponding designator in 

said updated-state map with the corresponding designator 
from said present-state map* 
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